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Amendments to the Claims: 

Please replace all prior versions, and listings of claims in the application with the 
following listing of claims. 

Listing of claims: 

CLAIMS: 

Claim 1 (original): A look up engine comprising a storage means for storing a plurality of 
entries, each entry comprising a value and an associated key value, such that, in operation, a 

look up is carried out by outputting a value which is associated with the stored key value 
which matches an input key value, the look up engine comprising a plurality of look up state 
machines connected in parallel to enable multiple look ups to be carried out concurrently. 

Claim 2 (original): A look up engine according to claim 1, wherein the entries are stored 
in a trie structure. 

Claim 3 (original): A look up engine according to claim 2, wherein the trie structure is a 
PATRICIA trie structure. 

Claim 4 (original): A look up engine according to claim 1 further comprising an input 
buffer and an output buffer. 

Claim 5 (original): A look up engine according to claim 4, wherein the look up engine 
further comprises a distributor for distributing the input key values between the plurality of 
look up state machines. 

Claim 6 (original): A look up engine according to claim 5, wherein the look up engine 
further comprises a collector for collecting the outputs from the plurality of look up state 
machines for outputting the lookup value. 

Claim 7 (original): A look up engine according to claim 1 , wherein the length of the key 
values and the values is fixed. 
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Claim 8 (currently amended): A look up engine according to any one of claims claim 1 , 
wherein the length of the key value and the values is variable. 

Claim 9 (original): A look up engine according to claim 1, wherein the look up engine 
further comprises a tagging mechanism in which each key value has a tag associated 
therewith such that the output values can be ordered in accordance with the order of receipt of 
the input key value. 

Claim 1 0 (original): A look up engine according to claim 1 , wherein the look up engine 
comprises means for storing the identity of a requestor requesting look up for each look up 
request such that the output value is sent to the correct location. 

Claim 1 1 (original): A look up engine according to claim 1, wherein at least one of the 
output values comprises an error message which is output to indicate a look up failure. 

Claim 12 (original): A look up engine according to claim 1 1, wherein the error message 
further comprising additional data including indication of the type of error. 

Claim 1 3 (original): A look up engine according to claim 12, wherein the additional data 
includes indication of the number of bits of the input key value which matched. 

Claim 14 (original): A look up engine according to claim 1 1, wherein each entry further 
comprises a skip value and each key value comprises a plurality of bits, and wherein the error 
message is sent if the skip value mismatches the skipped bits of the input key value. 

Claim 15 (original): A look up engine according to claim 1, wherein the storage means 
comprises internal and/or external memory. 

Claim 16 (original): A look up engine according to claim 15, wherein the storage means 
comprises a plurality of independent, parallel memory banks, each memory bank containing 
at least one table of the plurality of entries. 
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Claim 17 (original): A look up engine according to claim 16, wherein the tables are 
mutually exclusive. 

Claim 1 8 (original): A look up engine according to claim 17, wherein the input key value 
comprises a table identifier for identifying which of the tables is required. 

Claim 19 (currently amended): A look up engine according to claim 15, wherein the 
look up state machines can be bypassed in operation such that the storage means is utilised 

utilized as memory for a processing means- 
Claim 20 (original): A look up engine according to claim 19, wherein the storage means is 
dynamically partitioned for use as memory by the processing means and for storing the 
plurality of entries. 

Claim 21 (original): A method for looking up a value, the method comprising the steps of: 

(a) receiving a key value; 

(b) comparing the input key value with a plurality of stored key values; 

(c) outputting the value associated with the stored key value that matches the input 
key value, wherein steps (a), (b) and (c) are carried out concurrently. 

Claim 22 (original): A method for looking up a value, the method comprising the steps of: 

(a) receiving a key value; 

dividing the input key value into a plurality of predetermined portions; 

(b) comparing each predetermined portion of the input key value with a plurality 
of stored key values; 

(c) outputting the value associated with the stored key value that matches the 
predetermined portion of the input key value; 

(d) assembling each lookuped value to produce a final key value; 

(e) comparing the final key value with a plurality of stored key values; and 

(f) outputting the value associated with the stored key value that matches the final 
key value, wherein steps (b) to (d) are carried out concurrently. 
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Claim 23 (original): A computer system comprising a plurality of processing means 
interconnected via a bus system, the computer system further comprising a look up engine, 
the look up engine comprising a storage means for storing a plurality of entries, each entry 
comprising a value and an associated key value, such that, in operation, a look up is carried 
out by outputting a value which is associated with the stored key value which matches an 
input key value, the look up engine comprising a plurality of look up state machines 
connected in parallel to enable multiple look ups to be carried out concurrently. 

Claim 24 (original): A computer system according to claim 23, wherein the look up engine 
is connected to the bus system via a plurality of parallel interface units, the interface units 
allowing concurrent update of the entries and look up. 

Claim 25 (original): A computer system according to claim 23, wherein multiple keys are 
submitted for look up in a single bus transaction. 

Claim 26 (withdrawn): A look up engine comprising at least one storage means for 

storing a plurality of entries, each entry comprises a key value, an associated value and a skip 
value, such that, in operation a look up is carried out by outputting a value which is 
associated with the stored key value which matches an input key value, the input key 
comprising a plurality of bits, if the skipped bits of the input key value and the associated 
skip value mismatches, an error message is output to indicate lookup failure. 

Claim 27 (withdrawn): A look up engine according to claim 26, wherein the error 
message further comprising additional data including indication of the type of error. 

Claim 28 (withdrawn): A look up engine according to claim 26. wherein multiple look 
ups are carried out concurrently. 

Claim 29 (withdrawn): A method for looking up a value, each value having a key value 
and a skip value associated therewith, the method comprising the steps of: 
receiving a key value comprising a plurality of bits; 



PAGE 8/11 * RCVD AT 1MO/2005 4:45:58 PM [Eastern Standard Time] * SVR:USPTO-EFXRF-1/7 * DNIS:8729306 * CSID:1 703 718 8884 • DURATION (mm-ss):04-18 



Jan 10 2005 4:41PM Potomac Patent Group PLLC 1-703-718-8884 p. 9 

Application No.: 10/074,022 
New Attorney's Docket No. 032658-025 
New Attorney's Docket No. 01 1 9-025 

Page 6 

comparing the input key value with a plurality of stored key values; 

comparing the skip value associated with the value corresponding to the input key 
value with the skipped bits of the input key value; 

outputting the value associated with the stored key value that matches the input key 
value if the skip value matches the skipped bits of the input key value, and outputting an error 
message to indicate look up failure if the skip value does not match the skipped bits of the 
input key. 

Claim 30 (withdrawn): A method according to claim 29, wherein the output error 

message comprises additional data including an indication of the type of error. 

Claim 3 1 (withdrawn): A method according to claim 29, wherein multiple look ups are 

carried out concurrentiy. 

Claim 32 (withdrawn): A method of constructing a trie in a storage means, the trie 

comprising a plurality of entries, the method comprising the steps of: 

identifying overlapping ranges between the plurality of entries; 

splitting the identified overlapping ranges; 

storing the plurality of entries within a trie structure. 

Claim 33 (withdrawn): A method according to claim 32, wherein the depth of the trie 

is programmable. 

Claim 34 (withdrawn): A method according to claim 33, wherein the entries are 
arranged in a PATRICIA trie. 

Claim 35 (withdrawn): A method according to any one of claim 32, wherein, the 

method further comprises the step of: 

providing each entry with a skip value such that, during the look up operation, the 
skip value associated with the value corresponding to the input key value is compared with 
the skipped bits of the input key value; 
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outputting the value associated with the stored key value that matches the input key 
value if the skip value matches the skipped bits of the input key value, and outputting an error 
message to indicate look up failure if the skip value does not match the skipped bits of the 
input key. 

Claim 36 (withdrawn): A look up engine constructed and updated in accordance with a 

method of constructing a trie in a storage means, the trie comprising a plurality of entries, the 
method comprising the steps of: 

identifying overlapping ranges between the plurality of entries; 

splitting the identified overlapping ranges; 

storing the plurality of entries within a trie structure. 
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